**3주차 결과 보고서**

20150555 남민혁

**1. 실험 목적**

3주차 실험의 목적은 아래와 같다.

* AND/OR/NOT 게이트 동작의 이해와 확인
* Verilog를 사용하여 다중 입력 AND/OR/NOT 게이트의 구현
* 입력 신호 생성 후 Simulation를 통해 구현된 각 게이트의 동작을 확인

**2. FPGA 동작법을 설명하시오.**

FPGA는 아래 과정을 통하여 동작한다.

* Functional Architecture Design: 이론 및 스키메틱을 통해서 디자인을 설계한다.
* Design Entry: HDL을 통하여 위에서 설계한 내용을 코딩한다.
* RTL Simulation: 설계한 내용을 시뮬레이션으로 검증해본다.
* Device / Pin Assignment: 유저가 high-level에서 구현한 디자인을 적용할 특정한 FPGA 보드의 specification에 적용되도록 배정한다. 더불어 HDL에서 선언한 레지스터의 입출력 값을 보드의 특정 Pin과 매칭시켜 물리적인 입출력 값으로 적용한다.
* Synthesis / Implement: 앞에서 구현한 high-level 디자인을 FPGA 보드가 이해할 수 있는 low-level 즉, bitstream 파일을 생성한다.
* Device Configuration: FPGA보드를 사용하여 구현한 디자인이 실제로 구현되었는지 확인한다.

**![](data:image/png;base64,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)3. 3-input AND gate의 simulation 결과 및 과정에 대해서 설명하시오. (3 input, 2 output)[3장 ppt 31 page 참조 , 진리표 작성]**

**-Boolean 식**

|  |  |
| --- | --- |
| (A) | (B) |
| ABC=D | (AB)C=E |

**-Verilog 코딩**

|  |  |  |
| --- | --- | --- |
|  | (A) | (B) |
| Verilog | `timescale 1ns / 1ps  module three\_input\_and\_gate\_a(  input a,  input b,  input c,  output d  );  assign d = a & b & c;  endmodule | `timescale 1ns / 1ps  module three\_input\_and\_gate\_b(  input a,  input b,  input c,  output d,  output e  );  assign d = a & b;  assign e = c & d;  endmodule |
| Test Bench | module three\_input\_and\_gate\_a\_tb;  reg aa;  reg bb;  reg cc;  wire dd;  three\_input\_and\_gate\_a u\_three\_input\_and\_gate\_a(  .a (aa),  .b (bb),  .c (cc),  .d (dd)  );  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  initial begin  #800  $finish;  end  endmodule | module three\_input\_and\_gate\_b\_tb;  reg aa;  reg bb;  reg cc;  wire dd;  wire ee;  three\_input\_and\_gate\_b u\_three\_input\_and\_gate\_b(  .a (aa),  .b (bb),  .c (cc),  .d (dd),  .e (ee));  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  initial begin  #800  $finish;  end  endmodule |

**-Simulation 출력 결과 비교**

|  |  |
| --- | --- |
| A |  |
| B |  |

**-진리표**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Input A | Input B | Input C | Output D | Output E |
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 |
| 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 | 0 |
| 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 1 | 1 |

***Note*** (B)를 기준으로 작성되었으며, (A)는 위 진리표의 마지막 열에 있는 Output을 Output D로 고려하면 된다.

**4. 4-input AND gate의 simulation 결과 및 과정에 대해서 설명하시오. (4 input, 3 output)[3장 ppt 33 page 참조 , 진리표 작성]**

**-Boolean 식**

|  |  |
| --- | --- |
| A | B |
| ABCD=E | ((AB)C)D=G |

**-Verilog 코딩**

|  |  |  |
| --- | --- | --- |
|  | (A) | (B) |
| Verilog | `timescale 1ns / 1ps  module four\_input\_and\_gate\_b(  input a,  input b,  input c,  input d,  output e  );  assign e = a & b & c &d;  endmodule | `timescale 1ns / 1ps  module four\_input\_and\_gate\_b(  input a,  input b,  input c,  input d,  output e,  output f,  output g  );  assign e = a & b;  assign f = e & c;  assign g = f & d;  endmodule |
| Test Bench | module four\_input\_and\_gate\_a\_tb;  reg aa;  reg bb;  reg cc;  reg dd;  wire ee;  four\_input\_and\_gate\_a u\_four\_input\_and\_gate\_a(  .a (aa),  .b (bb),  .c (cc),  .d (dd),  .e (ee));  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  initial dd = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  always dd = #50 ~dd;  initial begin  #800  $finish;  end  endmodule | module four\_input\_and\_gate\_b\_tb;  reg aa;  reg bb;  reg cc;  reg dd;  wire ee;  wire ff;  wire gg;  four\_input\_and\_gate\_b u\_four\_input\_and\_gate\_b(  .a (aa),  .b (bb),  .c (cc),  .d (dd),  .e (ee),  .f (ff),  .g (gg));  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  initial dd = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  always dd = #50 ~dd;  initial begin  #800  $finish;  end  endmodule |

**-Simulation 출력 결과 비교**

|  |  |
| --- | --- |
| A |  |
| B |  |

**-진리표**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Input A | Input B | Input C | Input D | Output E | Output F | Output G |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 | 0 | 0 |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 1 | 0 | 0 | 0 |
| 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 0 | 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 0 | 1 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 |

***Note*** (B)를 기준으로 작성되었으며, (A)는 위 진리표의 마지막 열에 있는 Output을 Output E로 고려하면 된다.

**5. 3-input OR gate의 simulation 결과 및 과정에 대해서 설명하시오. (3 input, 2 output)[3장 ppt 35 page 참조, 진리표 작성]**

**-Boolean 식**

|  |  |
| --- | --- |
| A | B |
| A+B+C=D | (A+B)+C=E |

**-Verilog 코딩**

|  |  |  |
| --- | --- | --- |
|  | (A) | (B) |
| Verilog | `timescale 1ns / 1ps  module three\_input\_or\_gate\_a(  input a,  input b,  input c,  output d  );  assign d = a | b | c;  endmodule | `timescale 1ns / 1ps  module three\_input\_or\_gate\_b(  input a,  input b,  input c,  output d,  output e  );  assign d = a | b;  assign e = c | d;  endmodule |
| Test Bench | module three\_input\_or\_gate\_a\_tb;  reg aa;  reg bb;  reg cc;  wire dd;  three\_input\_or\_gate\_a u\_three\_input\_or\_gate\_a(  .a (aa),  .b (bb),  .c (cc),  .d (dd)  );  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  initial begin  #800  $finish;  end  endmodule | module three\_input\_or\_gate\_b\_tb;  reg aa;  reg bb;  reg cc;  wire dd;  wire ee;  three\_input\_or\_gate\_b u\_three\_input\_or\_gate\_b(  .a (aa),  .b (bb),  .c (cc),  .d (dd),  .e (ee));  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  initial begin  #800  $finish;  end  endmodule |

**-Simulation 출력 결과 비교**

|  |  |
| --- | --- |
| A |  |
| B |  |

**-진리표**

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| Input A | Input B | Input C | Output D | Output E |
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | 1 | 1 |
| 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 |

***Note*** (B)를 기준으로 작성되었으며, (A)는 위 진리표의 마지막 열에 있는 Output을 Output D로 고려하면 된다.

**6. 4-input OR gate의 simulation 결과 및 과정에 대해서 설명하시오. (4 input, 3 output)[3장 ppt 37 page 참조 , 진리표 작성]**

**-Boolean 식**

|  |  |
| --- | --- |
| A | B |
| A+B+C+D=E | ((A+B)+C)+D=G |

**-Verilog 코딩**

|  |  |  |
| --- | --- | --- |
|  | (A) | (B) |
| Verilog | `timescale 1ns / 1ps  module four\_input\_or\_gate\_a(  input a,  input b,  input c,  input d,  output e  );  assign e = a | b | c |d;  endmodule | `timescale 1ns / 1ps  module four\_input\_or\_gate\_b(  input a,  input b,  input c,  input d,  output e,  output f,  output g  );  assign e = a | b;  assign f = e | c;  assign g = f | d;  endmodule |
| Test Bench | module four\_input\_or\_gate\_a\_tb;  reg aa;  reg bb;  reg cc;  reg dd;  wire ee;  four\_input\_or\_gate\_a u\_four\_input\_or\_gate\_a(  .a (aa),  .b (bb),  .c (cc),  .d (dd),  .e (ee));  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  initial dd = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  always dd = #50 ~dd;  initial begin  #800  $finish;  end  endmodule | module four\_input\_or\_gate\_b\_tb;  reg aa;  reg bb;  reg cc;  reg dd;  wire ee;  wire ff;  wire gg;  four\_input\_or\_gate\_b u\_four\_input\_or\_gate\_b(  .a (aa),  .b (bb),  .c (cc),  .d (dd),  .e (ee),  .f (ff),  .g (gg));  initial aa = 1'b0;  initial bb = 1'b0;  initial cc = 1'b0;  initial dd = 1'b0;  always aa = #400 ~aa;  always bb = #200 ~bb;  always cc = #100 ~cc;  always dd = #50 ~dd;  initial begin  #800  $finish;  end  endmodule |

**-Simulation 출력 결과 비교**

|  |  |
| --- | --- |
| A |  |
| B |  |

**-진리표**

|  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- |
| Input A | Input B | Input C | Input D | Output E | Output F | Output G |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 | 0 | 1 |
| 0 | 0 | 1 | 0 | 0 | 1 | 1 |
| 0 | 0 | 1 | 1 | 0 | 1 | 1 |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 |
| 0 | 1 | 1 | 0 | 1 | 1 | 1 |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 1 | 0 | 1 | 0 | 1 | 1 | 1 |
| 1 | 0 | 1 | 1 | 1 | 1 | 1 |
| 1 | 1 | 0 | 0 | 1 | 1 | 1 |
| 1 | 1 | 0 | 1 | 1 | 1 | 1 |
| 1 | 1 | 1 | 0 | 1 | 1 | 1 |
| 1 | 1 | 1 | 1 | 1 | 1 | 1 |

***Note*** (B)를 기준으로 작성되었으며, (A)는 위 진리표의 마지막 열에 있는 Output을 Output E로 고려하면 된다.

**7. 결과 검토 및 논의사항**

Two-level로 구현한 결과와 One-level로 구현한 결과의 Simulation 결과는 다르지 않았다. 다만 중간 결과 출력을 위한 register를 추가적으로 사용하여 추가적인 결과를 출력할 수 있었다.

Verilog 코딩을 한 후 Schematic한 결과를 출력했을 때, One-level로 의도한 코드 역시 Two-level로 나타나, 이로 인하여 실험 결과가 잘못되었을 수도 있어 이 부분에 대한 추가적인논의가 필요해보인다.

**8. 추가 이론 조사 및 작성**

본 실험에서는 간단한 AND/OR 논리회로를 구현하였지만, 실제로 one-level과 two-level로 다르게 구현함에 따라 결과 출력까지 걸리는 시간이나, 제작에 필요한 비용적인 측면에서 차이가 생길 것으로 보인다. 구현 방식에 있어 차이는 있지만, 논리적으로는 모두 동일한 식임을 진리표와 Boolean 식을 통해 알 수 있었다.

**9. 참고 문헌**

강석태, “Verilog HDL Summary”, http://vlsi.hongik.ac.kr/lecture/%EC%8B%A4%ED%97%98/Verilog\_Summary.pdf.

레바스, “Verilog HDL 문법 (컴파일러 지시어, 조건문, 다중 분기, 반복문)”, https://rebas.kr/214?category=603584.

한국기술교육대학교 전기전자통신공학부, “디지털시스템 설계 및 실습” Verilog HDL 문법 강의자료, https://cms3.koreatech.ac.kr/sites/yjjang/down/dsys11/M01\_VerilogHDL01.pdf.

Treeroad, “Assignment”, https://treeroad.tistory.com/entry/Assignment.